package com.marvels.loanapply.dao;

import java.util.List;
import java.util.Map;

import org.apache.ibatis.annotations.Param;

import com.marvels.loanapply.dto.ChannelCostDTO;
import com.marvels.loanapply.dto.CheckBillDTO;
import com.marvels.loanapply.dto.FlowStatisticsDTO;

public interface LoanapplyCheckBillDao {

	/**
	 * 对账管理 流量统计
	 * @param laAttachAtmeTypeViewDTO
	 * @return
	 */
	public List<FlowStatisticsDTO> selectFlowStatistics(CheckBillDTO dto);
	
	/**
	 * 新版统计，提升查询速度
	 * @param dto
	 * @return
	 */
	public List<FlowStatisticsDTO> selectNewFlowStatistics(CheckBillDTO dto);
	
	/**
	 * 获取总贷款数和第一次贷款数
	 * @param dto
	 * @return
	 */
	public Map<String, Object> selectLoadCount(CheckBillDTO dto);
	
	/**
	 * 查询注册时间段内用户的放款数
	 * @param dto
	 * @return
	 */
	public Map<String, Object> selectLoadCountV2(CheckBillDTO dto);
	

	/**
	 * 获取续贷的用户证件号
	 * @return
	 */
	public List<String> selectContinueLoanUser(@Param("startDate")String startDate,@Param("endDate")String endDate);
	/**
	 * 根据用户名模糊查询相关user_id
	 * @param userName
	 * @return
	 */
	public String selectUserIdByName(@Param("userName")String userName);
	/**
	 * 根据手机号码获取用户姓名
	 * @param mobile
	 * @return
	 */
	public String selectUserNameByPhone(@Param("mobile")String mobile);


	public List<Map<String,String>> selectUserNameByPhone1(@Param("mobile")String mobile);
	/**
	 * 将财务的放款时间同步到ac_loan_apply_info表中
	 * @param loanId
	 * @return
	 */
	public Integer synchroMoneyHandOutTime(@Param("loanId")String loanId);
	
	/**
	 * 查询回款率
	 */
	public Double queryReturnSuccessRate(CheckBillDTO temDto);
	
	
	public Double queryReturnSuccessRateV2(CheckBillDTO temDto);
	
	/**
	 * 查询复贷率
	 * @param temDto
	 * @return
	 */
	public Double queryRepeatLoanRate(CheckBillDTO temDto);
	
	/**
	 * 查询渠道成本
	 * @param dto
	 * @return
	 */
	public List<ChannelCostDTO> queryChannelCost(CheckBillDTO dto);
	
	
	/**
	 * 查询出符合条件的渠道  --  功能查询性能优化
	 * @param temDto
	 * @return
	 */
	public List<String> selectFlowStatisticsChannelName(CheckBillDTO temDto);
}
